import Vue from 'vue'
import App from './App.vue'
//引入轮播组件
import Carousel from '@/components/Carousel'
import Pagination from '@/components/Pagination'
//三级联动组件---全局组件
import TypeNav from '@/components/TypeNav'
import VueLazyLoad from 'vue-lazyload'

//第一个参数：全局组件的名字  第二个参数：哪一个组件atm
Vue.component(TypeNav.name, TypeNav)
Vue.component(Carousel.name, Carousel)
Vue.component(Pagination.name, Pagination)

import { Button, MessageBox } from 'element-ui';
import atm from '@/assets/images/aoteman.gif'
//注册全局组件
Vue.component(Button.name, Button)
//ElementUI注册组件的时候，还有一种写法，挂在原型上
Vue.prototype.$msgbox = MessageBox;
Vue.prototype.$alert = MessageBox.alert;
Vue.use(VueLazyLoad, {
  //懒加载默认图片
  loading: atm
})

//引入自定义插件
import myPlugins from '@/plugins/myplugins'
Vue.use(myPlugins, { name: 'upper' })


//引入路由相关组件
import router from '@/router'
//测试
// import { reqCategoryList } from '@/api'
// reqCategoryList();
//引入仓库
import store from '@/store'

//引入MockServer.js---mock数据
import '@/mock/mockServe'

//引入swiper样式(直接引)
import 'swiper/css/swiper.css'

//统一接口api文件夹里面全部的请求函数
//统一引入
import * as API from '@/api'

Vue.config.productionTip = false

//引入表单校验插件
import '@/plugins/validate'

new Vue({
  render: h => h(App),
  //全局事件总线$bus配置
  beforeCreate() {
    Vue.prototype.$bus = this
    Vue.prototype.$API = API
  },
  //注册路由:底下的写法KV一致省略V[router小写的]
  //注册路由信息：当这里书写router的时候，组件身上都拥有$route,$router属性
  router,
  //注册仓库：组件实例的身上会多一个属性$store属性
  store
}).$mount('#app')

